package com.hnchances.studentscoresystem.mapper;

import com.hnchances.studentscoresystem.dto.request.GradesQueryDTO;
import com.hnchances.studentscoresystem.dto.response.GradesQueryResponse;
import com.hnchances.studentscoresystem.entity.Grades;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 成绩表 Mapper
 * 对应数据库表：grades
 * 支持多表关联查询（学生、班级、课程、考试）
 */
@Mapper
public interface GradesMapper {

    /**
     * 新增成绩
     */
    int insert(Grades grades);

    /**
     * 根据 ID 查询成绩（单表）
     */
    Grades selectById(@Param("id") Long id);

    /**
     * 更新成绩
     */
    int update(Grades grades);

    /**
     * 软删除成绩（修改 status 为 1）
     */
    int deleteById(@Param("id") Long id);

    /**
     * 多条件查询成绩（关联学生、班级、课程、考试）
     */
    List<GradesQueryResponse> selectByCondition(GradesQueryDTO queryDTO);
    @Select("select * from grades")
    List<Grades> selectAll();
}